package com.powerbank.usercenter.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;

import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * 用户档案实体类
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("user_profile")
public class UserProfile {

    /**
     * 主键ID
     */
    @TableId(value = "id", type = IdType.ASSIGN_ID)
    private Long id;

    /**
     * 用户ID
     */
    @TableField("user_id")
    private Long userId;

    /**
     * 用户等级：1-普通，2-银牌，3-金牌，4-钻石
     */
    @TableField("user_level")
    private Integer userLevel;

    /**
     * 信用分数
     */
    @TableField("credit_score")
    private BigDecimal creditScore;

    /**
     * 总订单数
     */
    @TableField("total_orders")
    private Integer totalOrders;

    /**
     * 总消费金额
     */
    @TableField("total_amount")
    private BigDecimal totalAmount;

    /**
     * 最后活跃时间
     */
    @TableField("last_active_time")
    private LocalDateTime lastActiveTime;

    /**
     * 用户偏好设置（JSON格式）
     */
    @TableField("preferences")
    private String preferences;

    /**
     * 邀请码
     */
    @TableField("invite_code")
    private String inviteCode;

    /**
     * 被邀请人数
     */
    @TableField("invited_count")
    private Integer invitedCount;

    /**
     * 创建时间
     */
    @TableField(value = "created_time", fill = FieldFill.INSERT)
    private LocalDateTime createdTime;

    /**
     * 更新时间
     */
    @TableField(value = "updated_time", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updatedTime;

    /**
     * 是否删除：0-否，1-是
     */
    @TableLogic
    @TableField("deleted")
    private Integer deleted;
}